package leetcode.editor.cn;

//给定一个经过编码的字符串，返回它解码后的字符串。 
//
// 编码规则为: k[encoded_string]，表示其中方括号内部的 encoded_string 正好重复 k 次。注意 k 保证为正整数。 
//
// 你可以认为输入字符串总是有效的；输入字符串中没有额外的空格，且输入的方括号总是符合格式要求的。 
//
// 此外，你可以认为原始数据不包含数字，所有的数字只表示重复的次数 k ，例如不会出现像 3a 或 2[4] 的输入。 
//
// 
//
// 示例 1： 
//
// 
//输入：s = "3[a]2[bc]"
//输出："aaabcbc"
// 
//
// 示例 2： 
//
// 
//输入：s = "3[a2[c]]"
//输出："accaccacc"
// 
//
// 示例 3： 
//
// 
//输入：s = "2[abc]3[cd]ef"
//输出："abcabccdcdcdef"
// 
//
// 示例 4： 
//
// 
//输入：s = "abc3[cd]xyz"
//输出："abccdcdcdxyz"
// 
//
// 
//
// 提示： 
//
// 
// 1 <= s.length <= 30 
// 
// s 由小写英文字母、数字和方括号
// '[]' 组成 
// s 保证是一个 有效 的输入。 
// s 中所有整数的取值范围为
// [1, 300] 
// 
//
// Related Topics 栈 递归 字符串 👍 1312 👎 0

import java.util.Stack;

//Java：【394】 - 字符串解码
public class LeetCode_394_DecodeString{
    public static void main(String[] args) {
        Solution solution = new LeetCode_394_DecodeString().new Solution();
                // TO TEST
        System.out.println(solution.decodeString("3[a2[c]]"));
    }
    
    //leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public String decodeString(String s) {
        StringBuffer sb = new StringBuffer();
        int len = s.length();
        Stack<Integer> stack = new Stack<>();
        int time = 0;
        for (int i = 0; i < len; i++) {
            char ch = s.charAt(i);
            if(ch=='['){
                stack.push(i);
            }else if(ch==']'){
                if(stack.size()==1){
                    String str = decodeString(s.substring(stack.peek()+1, i));
                    for (int j = 0; j <time; j++) {
                        sb.append(str);
                    }
                    time=0;
                }
                stack.pop();

            } else if (stack.isEmpty() && ch>='0' && ch <='9'){
                if(time==0) time = ch-'0';
                else time = time * 10 + ch-'0';
            }else if(time==0){
                sb.append(ch);
            }

        }
        return sb.toString();
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}
